/*
 * Copyright (c) 2023 Huawei Technologies Co., Ltd.
 * openUBMC is licensed under Mulan PSL v2.
 * You can use this software according to the terms and conditions of the Mulan PSL v2.
 * You may obtain a copy of Mulan PSL v2 at:
 *         http://license.coscl.org.cn/MulanPSL2
 * THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
 * EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
 * MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
 * See the Mulan PSL v2 for more details.
 */

#ifndef GEN_GPU_STATUS_INTERFACE_H
#define GEN_GPU_STATUS_INTERFACE_H

#include <device_tree/base.h>

namespace dev::gen {

class MC_API Gpu_Status : public mc::engine::interface<Gpu_Status> {
public:
    MC_INTERFACE("bmc.dev.Gpu.Status")

    property<uint8_t>  ECCModeEnabled;          ///< ECC模式当前使能状态
    property<uint8_t>  ECCModePendingEnabled;   ///< ECC模式重启后使能状态
    property<uint8_t>  ResetRequired;           ///< 是否需要重启
    property<uint32_t> DoubleBitErrorPageCount; ///< 双bit失效故障页个数
    property<uint32_t> SingleBitErrorPageCount; ///< 单bit失效故障页个数
};

} // namespace dev::gen

#endif // GEN_GPU_STATUS_INTERFACE_H
